草庐IT

php - 表的条件sql查询

全部标签

postgresql - 如何从 Go 中的 Cloud Function 连接到 Cloud-SQL?

对于一个项目,我正在尝试将云功能连接到云sql数据库设置,如thisquickstartguide中所述。.该功能配置在同一区域,服务帐户具有角色CloudSQL-Client。我通过我的计算机调用函数是这样的:gcloudfunctionscall--region=--data'{"recipient":"hello","requester":"hello","message":"test"}'与函数的连接正常,似乎只是对数据库的身份验证不起作用,但我不知道我失败的地方。我多次检查了密码、用户和连接名,重设了密码,还是不行。我发现了问题here与将云功能连接到云sql相关。我尝试用单

mongodb - 为什么我的 mongodb 查询返回 0 个结果?

这是我的数据库集合:使用此go代码,我尝试获取所有参与故事或使用给定ID创建故事的用户。funcmain(){forstf.DB==nil{}collection:=stf.DB.Collection("user")ctx,cancel:=context.WithTimeout(context.Background(),30*time.Second)defercancel()id,_:=primitive.ObjectIDFromHex("5cb4dd7e29d3dca573a73d4c")fter:=bson.M{"_id":id}involvedFilter:=bson.M{"st

go - 我应该为每个查询或其在 GraphQL 中的所有字段创建解析器吗?

我对使用GraphQL很感兴趣,而且我刚刚开始尝试使用它。在GraphQL中tutorial,可以看到下面的引用:EachfieldinaGraphQLschemaisbackedbyaresolver.但是如果你看gqlgen(这是一个用于构建GraphQL服务器的golang库)todoexample使用以下架构:...typeMyQuery{todo(id:ID!):TodolastTodo:Todotodos:[Todo!]!}typeMyMutation{createTodo(todo:TodoInput!):Todo!updateTodo(id:ID!,changes:Ma

sqlite - 有没有办法查看将参数应用于 sqlite 中的查询的结果?

我在Go中使用sqlite3,出于调试目的,我想查看将参数应用于带有替换的查询的结果,即使用?替换为实际参数。这可能吗?目前,我有如下代码,打印的FTS5查询看起来没问题:SELECTowneridFROM__ftsindexWHEREownertable=?AND__ftsindexMATCH?AND(__ftsindexMATCH?)LIMIT?;它没有返回错误,但它也没有找到它应该找到的东西,我不知道如何进一步调试它:fori:=rangetrails{ifi==0{s+=`(__ftsindexMATCH?`}else{s+=`OR__ftsindexMATCH?`}}s+="

go - Rethinkdb 仅查询子数组

假设我在一个名为alerts的表中有一个对象{id:"1"history:[{date:"somedate"hid:"1234"},{date:"somedate"hid:"1234"}]}{id:"2"history:[{date:"someotherdate"hid:"1235"},{date:"somedate"hid:"1234"}]}我想要一个仅包含所有警报的历史对象的数组。如果我使用诸如r.db("irrelevant").table("alerts").pluck("history")我最终得到的是整个结构,只有方括号,没有id。喜欢{history:[{hid:123,

mysql - golang 代码中 mysql 查询的自动递增不起作用

我正在开发一个使用以太坊区block链的项目,我想用block数据填充数据库,但是对于block_id自动增量不起作用。下面的代码是创建查询stmt,err:=db.Prepare("CREATETABLEIFNOTEXISTSblock(block_idbigintNOTNULLAUTO_INCREMENT,block_numvarchar(200),block_hashvarchar(200),tx_countint,PRIMARYKEY(block_id));")下面的代码用于插入数据funcInsertBlock(db*sql.DB,block_numstring,block_

sql - 在插入或更新时返回数据时,我还需要使用 `Exec` 吗?

根据GoDatabaseSQL,它说要使用Exec来修改数据,而Query是错误的,因为在调用Rows.Close()之前底层连接一直保持打开状态.但是,我能想到两种情况,询问正确的模式是什么。1)使用sql.Tx进行多次更新,这将保持连接直到Tx.Rollback或Tx.Commit。在这种情况下,这重要吗?2)在更新、插入或删除时返回数据(尤其是在使用非基于整数的行ID时,如UUID)。在这种情况下,QueryRow似乎是合适的,尤其是因为它返回的Row没有Close只是Scan.然而,一个Tx可以打开写入然后立即读取,但这通常是很多额外的工作。我是否遗漏了这两个案例?我使用的是P

sql - 如果未找到行,QueryRow().Scan() 将返回错误。怎么解决?

我花了很多时间试图解决这个问题。我有一个结构:typeTokenstruct{Id*int64`db:"id"`Email*string`db:"email"`OperationType*string`db:"operation_type"`Token*string`db:"token"`ExpirationDate*time.Time`db:"expiration_date"`}我有一个通过电子邮件找到一个token的函数:func(rRepo2)FindOneByEmail(ctxcontext.Context,emailstring,ct*Token)error{row:=r.D

sql - 删除用于测试套件的所有数据库记录的最佳方法是什么?

我有一个测试套件使用从YAML文件读取的种子污染我的数据库。我想知道是否有一种方法可以在运行测试后清理我的数据库(删除用于测试套件的所有记录)。//OpendbandreturnspointerandcloserfuncfuncprepareMySQLDB(t*testing.T)(db*sql.DB,closerfunc()error){db,err:=sql.Open("mysql","user:pass@/database")iferr!=nil{t.Fatalf("openmysqlconnection:%s",err)}returndb,db.Close}//Pollutem

postgresql - GORM 数据库中的自动迁移将不需要的字段添加到 SQL 表

当我在gorm数据库中创建表时,它向表中添加了我不需要的列。我不确定它是如何添加这些额外字段的。这导致我遇到一个错误,“pq:列“user_id”中的空值违反了非空约束”。“user_id”是添加的不需要的列。我正在使用gorm和postgreSQL。我的两个表之间存在多对多关系。我的第一个表已正确创建,第二个表stores是使用提供的字段加上两个不需要的字段创建的:“user_id”和“stores_id”。我尝试删除多对多关系以查看是否是问题所在,我尝试删除表并使用不同的字段重新创建它们。无论如何,我都无法摆脱这两个额外的列。第一个(工作)表:typeUserstruct{gorm